load("@io_bazel_rules_go//go:def.bzl", "go_library", "go_test")

go_library(
    name = "store",
    srcs = [
        "etcd.go",
        "store.go",
    ],
    importpath = "github.com/pingcap/tidb/pkg/store",
    visibility = ["//visibility:public"],
    deps = [
        "//pkg/config",
        "//pkg/config/kerneltype",
        "//pkg/keyspace",
        "//pkg/kv",
        "//pkg/parser/terror",
        "//pkg/util",
        "//pkg/util/etcd",
        "//pkg/util/intest",
        "//pkg/util/logutil",
        "@com_github_pingcap_errors//:errors",
        "@com_github_pingcap_kvproto//pkg/pdpb",
        "@io_etcd_go_etcd_client_v3//:client",
        "@org_golang_google_grpc//:grpc",
        "@org_golang_google_grpc//backoff",
        "@org_golang_google_grpc//keepalive",
        "@org_uber_go_zap//:zap",
    ],
)

go_test(
    name = "store_test",
    timeout = "short",
    srcs = [
        "batch_coprocessor_test.go",
        "etcd_test.go",
        "main_test.go",
        "store_test.go",
    ],
    embed = [":store"],
    flaky = True,
    shard_count = 24,
    deps = [
        "//pkg/config",
        "//pkg/config/kerneltype",
        "//pkg/domain",
        "//pkg/keyspace",
        "//pkg/kv",
        "//pkg/store/mockstore",
        "//pkg/store/mockstore/unistore",
        "//pkg/testkit",
        "//pkg/testkit/external",
        "//pkg/testkit/testsetup",
        "@com_github_pingcap_errors//:errors",
        "@com_github_pingcap_failpoint//:failpoint",
        "@com_github_pingcap_kvproto//pkg/metapb",
        "@com_github_stretchr_testify//require",
        "@com_github_tikv_client_go_v2//kv",
        "@com_github_tikv_client_go_v2//testutils",
        "@org_uber_go_goleak//:goleak",
    ],
)
